回溯法与递归 C++中动态的二维数组

leetcode的题目,求出数独游戏的一个解。之前记得求解 全排列和八皇后问题也是用的回溯法。分治法可以用递归是很显然的,它们俩是天生一对;回溯法也可以。因为 试探求解 子问题。下面代码是递归回溯求解数独的一个解,6个测试用例,184ms,在C++分布段上处在中间,还行吧,以后有时间再研究。 关键是学到了一种方便地表示动态二维数组的新方法。一维的动态数组 就用new[]、vec
摘要由CSDN通过智能技术生成

leetcode的题目,求出数独游戏的一个解。

之前记得求解 全排列和八皇后问题也是用的回溯法。

分治法可以用递归是很显然的,它们俩是天生一对;回溯法也可以。因为 试探求解 子问题

下面代码是我用递归回溯求解数独的一个解,6个测试用例,184ms,在C++分布段上处在中间,还行吧,以后有时间再研究。

 

关键是学到了一种方便地表示动态二维数组的新方法。一维的动态数组 就用new[]、vector、deque。二维的呢?

  1、旧方法,比如:

int* baseAddr=new int[3*2]; // 3 行 2 列
typedef int int2 [2];
int2 * p=(int2 *)baseAddr;
for(int i=0;i<3;i++)
{
	for(int j=0;j<2;j++)
	{
		p[i][j]=i*2+j;
	}
}
delete [] baseAddr;

  2、新方法,比如这道求解数独的题目:
#include <vector>
using namespace std;
void solveS
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值